<script lang="ts" setup>
import { type TableType, ViewTypes, viewTypeAlias } from 'nocodb-sdk'

const { $e } = useNuxtApp()

const { isUIAllowed, orgRoles, workspaceRoles } = useRoles()

const { openedProject, showProjectList } = storeToRefs(useBases())

const { base, isSharedBase } = storeToRefs(useBase())

const tablesStore = useTablesStore()
const { openTableCreateDialog: _openTableCreateDialog } = tablesStore
const { activeTable } = storeToRefs(tablesStore)

const { openNewScriptModal } = useAutomationStore()

const { openNewDashboardModal } = useDashboardStore()

const viewsStore = useViewsStore()
const { loadViews, onOpenViewCreateModal } = viewsStore
const { activeView } = storeToRefs(viewsStore)

const { isAiFeaturesEnabled } = useNocoAi()

const isVisibleCreateNew = ref(false)

const baseCreateDlg = ref(false)

const isViewListLoading = ref(false)

const toBeCreateType = ref<ViewTypes | 'AI'>()

const isSqlView = computed(() => (activeTable.value as TableType)?.type === 'view')

const activeSource = computed(() => {
  return base.value.sources?.find((s) => s.id === activeView.value?.source_id)
})

async function onOpenModal({
  title = '',
  type,
  copyViewId,
  groupingFieldColumnId,
  calendarRange,
  coverImageColumnId,
}: {
  title?: string
  type: ViewTypes | 'AI'
  copyViewId?: string
  groupingFieldColumnId?: string
  calendarRange?: Array<{
    fk_from_column_id: string
    fk_to_column_id: string | null // for ee only
  }>
  coverImageColumnId?: string
}) {
  if (isViewListLoading.value) return

  $e('c:view:create:mini-sidebar', { view: type === 'AI' ? type : viewTypeAlias[type] })

  toBeCreateType.value = type

  isViewListLoading.value = true
  try {
    await loadViews({
      tableId: activeTable.value.id!,
    })
  } catch (e) {
    console.log('error', e)
  }

  isVisibleCreateNew.value = false
  isViewListLoading.value = false

  onOpenViewCreateModal({
    title,
    type,
    copyViewId,
    groupingFieldColumnId,
    calendarRange,
    coverImageColumnId,
    baseId: base.value.id!,
    tableId: activeTable.value.id!,
    sourceId: activeTable.value?.source_id,
  })
}

function openTableCreateDialog() {
  _openTableCreateDialog({
    baseId: base.value?.id,
    sourceId: base.value!.sources?.[0].id,
  })
}

const hasBaseCreateAccess = computed(() => {
  if (isEeUI) {
    return isUIAllowed('baseCreate')
  }

  return isUIAllowed('baseCreate', { roles: workspaceRoles ?? orgRoles })
})

const isBaseHomePage = computed(() => {
  return !showProjectList.value && !!openedProject.value
})

const hasTableCreateAccess = computed(() => {
  if (!base.value || !isBaseHomePage.value) return true

  return isUIAllowed('tableCreate', {
    roles: base.value?.project_role || base.value.workspace_role,
    source: base.value?.sources?.[0],
  })
})

const hasViewCreateAccess = computed(() => {
  if (!base.value || !isBaseHomePage.value) return true

  return isUIAllowed('viewCreateOrEdit')
})

const hasAutomationCreateAccess = computed(() => {
  if (!base.value || !isBaseHomePage.value) return true

  return isUIAllowed('scriptCreateOrEdit')
})

const hasDashboardCreateAccess = computed(() => {
  if (!base.value || !isBaseHomePage.value) return true

  return isUIAllowed('dashboardCreate')
})
</script>

<template>
  <div v-if="!isSharedBase" class="nc-mini-sidebar-btn-full-width">
    <NcDropdown v-model:visible="isVisibleCreateNew" placement="right" overlay-class-name="!min-w-48">
      <div class="w-full py-1 flex items-center justify-center">
        <div
          class="border-1 w-7 h-7 flex-none rounded-full overflow-hidden transition-all duration-300 flex items-center justify-center bg-nc-bg-gray-medium"
          :class="{
            'border-nc-border-gray-dark': !isVisibleCreateNew,
            'active border-primary shadow-selected': isVisibleCreateNew,
          }"
        >
          <GeneralIcon icon="ncPlus" />
        </div>
      </div>

      <template #overlay>
        <NcMenu variant="small" @click="isVisibleCreateNew = false">
          <NcMenuItemLabel>
            <span class="normal-case">
              {{ $t('labels.createNew') }}
            </span>
          </NcMenuItemLabel>
          <NcMenuItem v-if="hasBaseCreateAccess" data-testid="mini-sidebar-base-create" @click="baseCreateDlg = true">
            <GeneralIcon icon="ncBaseOutline" class="h-4 w-4" />
            {{ $t('objects.project') }}
          </NcMenuItem>
          <NcTooltip
            :title="
              hasTableCreateAccess ? $t('tooltip.navigateToBaseToCreateTable') : $t('tooltip.youDontHaveAccessToCreateNewTable')
            "
            :disabled="!(!isBaseHomePage || !hasTableCreateAccess)"
            placement="right"
          >
            <NcMenuItem
              data-testid="mini-sidebar-table-create"
              :disabled="!isBaseHomePage || !hasTableCreateAccess"
              @click="openTableCreateDialog"
            >
              <GeneralIcon icon="table" />
              {{ $t('objects.table') }}
            </NcMenuItem>
          </NcTooltip>

          <template v-if="isEeUI">
            <NcTooltip
              :title="
                hasDashboardCreateAccess
                  ? $t('tooltip.navigateToBaseToCreateDashboard')
                  : $t('tooltip.youDontHaveAccessToCreateNewDashboard')
              "
              :disabled="!(!isBaseHomePage || !hasDashboardCreateAccess)"
              placement="right"
            >
              <NcMenuItem
                data-testid="mini-sidebar--dashboard-create"
                :disabled="!isBaseHomePage || !hasDashboardCreateAccess"
                @click="openNewDashboardModal({ baseId: openedProject?.id })"
              >
                <GeneralIcon icon="dashboards" />
                {{ $t('general.dashboard') }}
              </NcMenuItem>
            </NcTooltip>
          </template>

          <NcTooltip
            :title="
              hasViewCreateAccess ? $t('tooltip.navigateToTableToCreateView') : $t('tooltip.youDontHaveAccessToCreateNewView')
            "
            :disabled="!(!base || !activeTable || !hasViewCreateAccess)"
            placement="right"
          >
            <NcSubMenu
              class="py-0"
              data-testid="mini-sidebar-view-create"
              variant="small"
              :disabled="!base || !activeTable || !hasViewCreateAccess"
            >
              <template #title>
                <GeneralIcon icon="grid" />
                {{ $t('objects.view') }}
              </template>
              <NcMenuItem data-testid="mini-sidebar-view-create-grid" @click.stop="onOpenModal({ type: ViewTypes.GRID })">
                <GeneralViewIcon :meta="{ type: ViewTypes.GRID }" />
                <div>{{ $t('objects.viewType.grid') }}</div>
              </NcMenuItem>
              <NcTooltip :title="$t('tooltip.sourceDataIsReadonly')" :disabled="!activeSource?.is_data_readonly && !isSqlView">
                <NcMenuItem
                  :disabled="!!activeSource?.is_data_readonly || isSqlView"
                  data-testid="mini-sidebar-view-create-form"
                  @click="onOpenModal({ type: ViewTypes.FORM })"
                >
                  <GeneralViewIcon
                    :meta="{ type: ViewTypes.FORM }"
                    :class="{
                      'opacity-50': !!activeSource?.is_data_readonly || isSqlView,
                    }"
                  />
                  <div>{{ $t('objects.viewType.form') }}</div>
                </NcMenuItem>
              </NcTooltip>
              <NcMenuItem data-testid="mini-sidebar-view-create-gallery" @click="onOpenModal({ type: ViewTypes.GALLERY })">
                <GeneralViewIcon :meta="{ type: ViewTypes.GALLERY }" />
                <div>{{ $t('objects.viewType.gallery') }}</div>
              </NcMenuItem>
              <NcMenuItem data-testid="mini-sidebar-view-create-kanban" @click="onOpenModal({ type: ViewTypes.KANBAN })">
                <GeneralViewIcon :meta="{ type: ViewTypes.KANBAN }" />
                <div>{{ $t('objects.viewType.kanban') }}</div>
              </NcMenuItem>
              <NcMenuItem data-testid="mini-sidebar-view-create-calendar" @click="onOpenModal({ type: ViewTypes.CALENDAR })">
                <GeneralViewIcon :meta="{ type: ViewTypes.CALENDAR }" class="!w-4 !h-4" />
                <div>{{ $t('objects.viewType.calendar') }}</div>
              </NcMenuItem>
              <template v-if="isAiFeaturesEnabled">
                <NcDivider />
                <NcMenuItem data-testid="mini-sidebar-view-create-ai" @click="onOpenModal({ type: 'AI' })">
                  <GeneralIcon icon="ncAutoAwesome" class="!w-4 !h-4 text-nc-fill-purple-dark" />
                  <div>{{ $t('labels.useNocoAI') }}</div>
                </NcMenuItem>
              </template>
            </NcSubMenu>
          </NcTooltip>

          <template v-if="isEeUI">
            <NcDivider />
            <NcTooltip
              :title="
                hasAutomationCreateAccess
                  ? $t('tooltip.navigateToBaseToCreateAutomation')
                  : $t('tooltip.youDontHaveAccessToCreateNewAutomation')
              "
              :disabled="!(!isBaseHomePage || !hasAutomationCreateAccess)"
              placement="right"
            >
              <NcMenuItem
                data-testid="mini-sidebar--script-create"
                :disabled="!isBaseHomePage || !hasAutomationCreateAccess"
                @click="openNewScriptModal({ baseId: openedProject?.id })"
              >
                <GeneralIcon icon="ncScript" />
                {{ $t('general.script') }}
              </NcMenuItem>
            </NcTooltip>
          </template>
          <!-- <NcDivider />
          <NcTooltip title="Navigate to a view to a create record" :disabled="!!activeView" placement="right">
            <NcMenuItem data-testid="mini-sidebar-record-create" :disabled="!activeView" class="capitalize">
              <GeneralIcon icon="ncPlus" />
              {{ $t('objects.record') }}
            </NcMenuItem>
          </NcTooltip> -->
        </NcMenu>
      </template>
    </NcDropdown>
    <WorkspaceCreateProjectDlg v-model="baseCreateDlg" is-create-new-action-menu />
  </div>
</template>
